#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <vector>

using namespace std;

bool isMatch(string s, string p) {
    int m = p.size();
    int n = s.size();

    vector<vector<bool>> dp(m, vector<bool>(n));
    dp[0][0] = true;

    for (int i = 0; i < m; ++i)
    {
        if (p[i] == '*') dp[0][i] = true;
        else
            break;
    }

    for (int i = 1; i <= m; ++i)
    {
        for (int j = 1; j <= n; ++j)
        {
            if (p[i - 1] == '*')
                dp[i][j] = dp[i - 1][j];
            else if (p[i - 1] == '?' || s[j - 1] == p[i - 1])
                dp[i][j] = dp[i - 1][j - 1];
        }
    }

    return dp[m][n];
}

int main()
{
    isMatch("aa", "a");
	return 0;
}